Part Number Hot Search : 
LK115D50 SR30A0CT PELC5 BCM8152 1C220 D4448 FM25V01 BCM8152
Product Description
Full Text Search
 

To Download MU9C1480B-70TAI Datasheet File

  If you can't view the Datasheet, Please click here to try to view without PDF Reader .  
 
 


  Datasheet File OCR Text:
  data sheet music semiconductors, the music logo, and the phrase "music semiconductors" are november 5, 2002 rev. 2 registered trademarks of music semiconductors. music is a trademark of music semiconductors. application benefits  new low-cost lancam family in a space-saving tqfp package  fast speed allows processing of both da and sa within 450 ns, equivalent to 138 ports of 10 base-t or 13 ports of 100 base-t ethernet  full cam features allow all operations to be masked on a bit-by-bit basis  powerful, lancam a/l compatible instruction set for any list processing need  shiftable comparand and mask registers assist in proximate matching algorithms  cascadable to any practical length with no performance penalties  industrial temperature grades for harsh environments  dual footprint connections to conserve board space  3.3 volt for lower power systems distinctive characteristics  high density cmos content addressable memory (cam)  1k (1480b), 4k (4480b), 8k (8480b) words  64-bit per word memory organization  16-bit i/o  fast 50 ns compare speed  dual configuration register set for rapid context switching  16-bit cam/ram segments with music?s patented partitioning  /ma and /mm output flags to enable faster system performance  readable device id  selectable faster operating mode with no wait states after a no-match  validity bit setting accessible from the status register  single cycle reset for segment control register  44- and 64-pin tqfp package  3.3 volt operation figure 1: lancam b family block diagram /ec dq(15?0) (16) cam array 2 n words x 64 bits comparand* mask 1 mask 2 2 n x 2 v a l i d i t y b i t s p r i o r i t y e n c o d e r commands & status 2 n data (16) translate 802.3/802.5 data (16) demux next free address (r/o) control segment control page address (local) device select (global) address status (31-16) (r/o) register set 2 match addr & /ma flag /mm, /fl data (16) (16) data (64) data (64) a d d r e s s d e c o d e r /ma /mm n+1 16 i / o b u f f e r s control source and destination segment counters mux vcc gnd /ff /fi /mf /mi match and flag logic /w /e /cm /reset instruction(w/o)* status (15-0) (r/o)* lancam b family lancam b familylancam b family lancam b family
lancam b family general description 2 rev. 2 general description the lancam consists of various depths of 64-bit content addressable memories (cams), with a 16-bit wide interface. cams, also known as associative memories, operate in the converse way to random access memories (ram). in ram, the input to the device is an address and the output is the data stored at that address. in cam, the input is a data sample and the output is a flag to indicate a match and the address of the matching data. as a result, cam searches large databases for matching data in a short, constant time period, no matter how many entries are in the database. the ability to search data words up to 64 bits wide allows large address spaces to be searched rapidly and efficiently. a patented architecture links each cam entry to associated data and makes this data available for use after a successful compare operation. the music lancams are ideal for address filtering and translation applications in lan switches and routers. the lancams are also well suited to encryption, database accelerators, and image processing. operational overview to use the lancam, the user loads the data into the comparand register, which is automatically compared to all valid cam locations. the device then indicates whether or not one or more of the valid cam locations contains data that matches the target data. the status of each cam location is determined by two validity bits at each memory location. the two bits are encoded to render four validity conditions: valid, empty, skip, and ram, shown in status register bits on page 24 (bits 29:28). the memory can be partitioned into cam and associated ram segments on 16-bit boundaries, but by using one of the two available mask registers, the cam/ram partitioning can be set at any arbitrary size between zero and 64 bits. the lancam?s internal data path is 64 bits wide for rapid internal comparison and data movement. vertical cascading of additional lancams in a daisy chain fashion extends the cam memory depth for large databases. cascading requires no external logic. loading data to the control, comparand, and mask registers automatically triggers a compare. compares also may be initiated by a command to the device. associated ram data is available immediately after a successful compare operation. the status register reports the results of compares including all flags and addresses. two mask registers are available and can be used in two different ways: to mask comparisons or to mask data writes. the ram validity type allows additional masks to be stored in the cam array where they may be retrieved rapidly. a simple four-wire control interface and commands loaded into the instruction decoder control the device. a powerful instruction set increases the control flexibility and minimizes software overhead. additionally, dedicated pins for match and multiple-match flags enhance performance when the device is controlled by a state machine. these and other features make the lancam a powerful associative memory that drastically reduces search delays.
pin descriptions lancam b family rev. 2 3 pin descriptions note: all signals are implemented in cmos technology with ttl levels. signal names that start with a slash (?/?) are active low. inputs should never be left floating. the cam architecture draws large currents during compare operations, mandating the use of good layout and bypassing techniques. refer to the dc electrical characteristics on page 25 for more information. figure 2: 44-pin tqfp figure 3: 64-pin tqfp /e (chip enable, input, ttl) the /e input enables the device while low. the falling edge registers the control signals /w, /cm, and /ec. the rising edge locks the daisy chain, turns off the dq pins, and clocks the destination and source segment counters. the four cycle types enabled by /e are shown in table 1. /w (write enable, input, ttl) the /w input selects the direction of data flow during a device cycle. /w low selects a write cycle and /w high selects a read cycle. /cm (data/command select, input, ttl) the /cm input selects whether the input signals on dq15?0 are data or commands. /cm low selects command cycles and /cm high selects data cycles. /ec (enable daisy chain, input, ttl) the /ec signal performs two functions. the /ec input enables the /mf output to show the results of a comparison, as shown in figure 9 on page 14. if /ec is low at the falling edge of /e in a given cycle, the /mf output is enabled. otherwise, the /mf output is held high. the /ec signal also enables the /mf?/mi daisy chain, which serves to select the device with the highest-priority match in a string of lancams. table 4 explains the effect of the /ec signal on a device with or without a match in both standard and enhanced modes. /ec must be high during initialization. dq15?0 (data bus, i/o, ttl) the dq15?0 lines convey data, commands, and status to and from the lancam. /w and /cm control the direction and nature of the information that flows to or from the device. when /e is high, dq15?0 go to high-z. /mf (match flag, output, ttl) the /mf output goes low when one or more valid matches occur during a compare cycle. /mf becomes valid after /e goes high on the cycle that enables the daisy chain (on the first cycle that /ec is registered low by the previous falling edge of /e; see figure 9 on page 14). in a daisy chain, valid match(es) in higher priority devices are passed from the /mi input to /mf. if the daisy chain is enabled but the match flag is disabled in the control register, the /mf output only depends on the /mi input of the device (/mf=/mi). /mf is high if there is no match or when the daisy chain is disabled (/e goes high when /ec was high on the previous falling edge of /e). the system match flag is the /mf pin of the last device in the daisy chain. /mf is reset when the active configuration register set is changed. 44-pin tqfp (top view) /mm /ff /fi /cm /ec gnd dq0 dq1 dq2 dq3 vcc gnd dq4 dq5 vcc vcc test2 gnd gnd dq6 dq7 vcc gnd dq15 dq14 dq13 dq12 gnd dq11 dq10 dq9 dq8 gnd /ma /mi /mf gnd / rese vcc vcc test1 /e /w gnd 22 21 20 19 18 17 16 15 14 13 12 33 32 31 30 29 28 27 26 25 24 23 1 2 3 4 5 6 7 8 9 10 11 34 35 36 37 38 39 40 41 42 43 44 dq15 dq14 dq13 dq12 16 15 14 13 12 1 2 3 4 5 6 7 8 9 10 11 22 21 20 19 18 17 24 23 28 27 26 25 32 31 30 29 37 38 39 40 41 42 43 44 33 34 35 36 45 46 47 48 58 59 60 61 62 63 56 57 52 53 54 55 49 50 64 51 nc dq4 dq5 vcc vcc test2 gnd gnd dq6 dq7 vcc nc gnd gnd gnd nc gnd gnd dq11 dq10 dq9 dq8 gnd nc gnd gnd gnd nc /ma /mi /mf gnd /reset vcc vcc test1 /e /w gnd nc nc gnd gnd nc 64-pin tqfp (top view) /mm /ff /fi /cm /ec gnd dq0 dq1 dq2 dq3 vcc nc nc gnd nc nc table 1: i/o cycles /w /cm cycle type low low command write cycle low high data write cycle high low command read cycle high high data read cycle
lancam b family pin descriptions 4 rev. 2 /mi (match input, input, ttl) the /mi input prioritizes devices in vertically cascaded systems. it is connected to the /mf output of the previous device in the daisy chain. the /mi pin on the first device in the chain must be tied high. /ma (device match flag, output, ttl) the /ma output is low when one or more valid matches occur during the current or the last previous compare cycle. the /ma output is not qualified by /ec or /mi, and reflects the match flag from that specific device?s status register. /ma is reset when the active register set is changed. /mm (device multiple match flag, output, ttl) the /mm output is low when more than one valid match occurs during the current or the last previous compare cycle. the /mm output is not qualified by /ec or /mi, and reflects the multiple match flag from that specific device?s status register. /mm is reset when the active register set is changed. /ff (full flag, output, ttl) if enabled in the control register, the /ff output goes low when no empty memory locations exist within the device (and in the daisy chain above the device as indicated by the /fi pin). the system full flag is the /ff pin of the last device in the daisy chain, and the next free address resides in the device with /fi low and /ff high. if disabled in the control register, the /ff output only depends on the /fi input (/ff = /fi). /fi (full input, input, ttl) the /fi input generates a cam-memory-system-full indication in vertically cascaded systems. it is connected to the /ff output of the previous device in the daisy chain. the /fi pin on the first device in a chain must be tied low. /reset (reset, input, ttl) /reset must be driven low to place the device in a known state before operation, which resets the device to the conditions shown in table 3 on page 11. the /reset pin should be driven by ttl levels, not directly by an rc timeout. /e must be kept high during /reset. test1, test2 (test, input, ttl) these pins enable music production test modes that are not usable in an application. they should be connected to ground, either directly or through a pull-down resistor, or they may be left unconnected. these pins may not be implemented on all versions of these products. vcc, gnd (positive power supply, ground) these pins are the power supply connections to the lancam. vcc must meet the voltage supply requirements in the operating conditions section relative to the gnd pins, which are at 0 volts (system reference potential), for correct operation of the device. all the ground and power pins must be connected to their respective planes with adequate bulk and high frequency bypassing capacitors in close proximity to the device.
functional description lancam b family rev. 2 5 functional description the lancam is a content addressable memory (cam) with 16-bit i/o for network address filtering and translation, virtual memory, data compression, caching, and table lookup applications. the memory consists of static cam, organized in 64-bit data fields. each data field can be partitioned into a cam and a ram subfield on 16-bit boundaries. the contents of the memory can be randomly accessed or associatively accessed by the use of a compare. during automatic comparison cycles, data in the comparand register is automatically compared with the ?valid? entries in the memory array. the device id can be read using a tco ps instruction (see persistent source register bits on page 24). data input and output characteristics the data inputs and outputs of the lancam are multiplexed for data and instructions over a 16-bit i/o bus. internally, data is handled on a 64-bit basis, since the comparand register, the mask registers, and each memory entry are 64 bits wide. memory entries are globally configurable into cam and ram segments on 16-bit boundaries, as described in us patent 5,383,146 assigned to music semiconductors. seven different cam/ram splits are possible, with the cam width going from one to four segments, and the remaining ram width going from three to zero segments. finer resolution on compare width is possible by invoking a mask register during a compare, which allows global masking on a bit basis. the cam subfield contains the associative data, which enters into compares, while the ram subfield contains the associated data, which is not compared. in lan bridges, the ram subfield could hold, for example, port-address and aging information related to the destination or source address information held in the cam subfield of a given location. in a translation application, the cam field could hold the dictionary entries, while the ram field holds the translations, with almost instantaneous response. validity bits each entry has two validity bits associated with it to define its particular type: empty, valid, skip, or ram. when data is written to the active comparand register, and the active segment control register reaches its terminal count, the contents of the comparand register are automatically compared with the cam portion of all the valid entries in the memory array. for added versatility, the comparand register can be barrel-shifted right or left one bit at a time. a compare instruction then can be used to force another compare between the comparand register and the cam portion of memory entries of any one of the four validity types. after a read or move from memory operation, the validity bits of the location read or moved are copied into the status register, where they can be read using command read cycles. data movement (read/write) data can be moved from one of the data registers (cr, mr1, or mr2) to a memory location that is based on the results of the last comparison (highest-priority match or next free), or to an absolute address, or to the location pointed to by the active address register. data can also be written directly to the memory from the dq bus using any of the above addressing modes. the address register may be directly loaded and may be set to increment or decrement, allowing dma-type reading or writing from memory. configuration register sets two sets of configuration registers (control, segment control, address, mask register 1, and persistent source and destination) are provided to permit rapid context switching between foreground and background activities. the currently active set of configuration registers controls writes, reads, moves, and compares. the foreground set typically would be pre-loaded with values useful for comparing input data, often called filtering, while the background set would be pre-loaded with values useful for housekeeping activities such as purging old entries. moving from the foreground task of filtering to the background task of purging can be done by issuing a single instruction to change the current set of configuration registers. the match condition of the device is reset whenever the active register set is changed. control register the active control register determines the operating conditions within the device. conditions set by this register?s contents are reset, enable or disable match flag, enable or disable full flag, cam/ram partitioning, disable or select masking conditions, disable or select auto-incrementing or auto-decrementing the address register, and select standard or enhanced mode. the active segment control register contains separate counters to control the writing of 16-bit data segments to the selected persistent destination, and to control the reading of 16-bit data segments from the selected persistent source. mask registers there are two active mask registers at any one time, which can be selected to mask comparisons or data writes. mask register 1 has both a foreground and background mode to support rapid context switching. mask register 2 does not have this mode, but can be shifted left or right one bit at a time. for masking comparisons, data stored in the active selected mask register determines which bits of the comparand are compared against the valid contents of the memory. if a bit is set high in the mask register, the same bit position in the comparand register becomes a ?don?t
lancam b family functional description 6 rev. 2 care? for the purpose of the comparison with all the memory locations. during a data write cycle or a mov instruction, data in the specified active mask register can also determine which bits in the destination are updated. if a bit is high in the mask register, the corresponding bit of the destination is unchanged. highest priority/multiple match the match line associated with each memory address is fed into a priority encoder where multiple responses are resolved, and the address of the highest-priority responder (the lowest numerical match address) is generated. in lan applications, a multiple response might indicate an error. in other applications the existence of multiple responders may be valid. input control signals and commands four input control signals and commands loaded into an instruction decoder control the lancam. two of the four input control signals determine the cycle type. the control signals tell the device whether the data on the i/o bus represents data or a command, and is input or output. commands are decoded by instruction logic and control moves, forced compares, validity bit manipulations, and the data path within the device. registers (control, segment control, address, next free address, etc.) are accessed using temporary command override instructions. the data path from the dq bus to/from data resources (comparand, masks, and memory) within the device are set until changed by select persistent source and destination instructions. after a compare cycle (caused by either a data write to the comparand or mask registers, a write to the control register, or a forced compare), the status register contains the address of the highest-priority matching location in that device, concatenated with its page address, along with flags indicating internal match, multiple match, and full. when the status register is read with a command read cycle, the device with the highest-priority match responds, outputting the system match address to the dq bus. the internal match (/ma) and multiple match (/mm) flags are also output on pins. another set of flags (/mf and /ff) that are qualified by the match and full flags of previous devices in the system also are available directly on output pins, and are independently daisy-chained to provide system match and full flags in vertically cascaded lancam arrays. in such arrays, if no match occurs during a comparison, read access to the memory and all the registers except the next free register is denied to prevent device contention. in a daisy chain, all devices respond to command and data write cycles, depending on the conditions shown in table 4 unless the operation involves the highest-priority match address or the next free address; in which case, only the specific device having the highest-priority match or the next free address responds. cascading lancams a page address register in each device simplifies vertical expansion in systems using more than one lancam. this register is loaded with a specific device address during system initialization, which then serves as the higher-order address bits. a device select register allows the user to target a specific device within a vertically cascaded system by setting it equal to the page address register value, or to address all the devices in a string at the same time by setting the device select value to ffffh. figure 4 shows expansion using a daisy chain. note that system flags are generated without the need for external logic. the page address register allows each device in the vertically cascaded chain to supply its own address in the event of a match, eliminating the need for an external priority encoder to calculate the complete match address at the expense of the ripple-through time to resolve the highest-priority match. the full flag daisy-chaining allows associative writes using a move to next free address instruction, which does not need a supplied address. figure 5 shows an external pld implementation of a simple priority encoder that eliminates the daisy chain ripple-through delays for systems requiring maximum performance from many cams.
functional description lancam b family rev. 2 7 figure 4: vertical cascading figure 5: external prioritizing vcc /mi /fi /ff /mf lancam 16 /e /w /cm /ec dq15?0 /mi /fi /mf /mi /fi /mf /e /w /cm /ec dq15?0 /e /w /cm /ec dq15?0 /e /w /cm /ec dq15?0 lancam lancam /ff system full system match /ff /ma /ma /ma /ma lancam /mi /mi /mi /mi v cc pld lancam lancam lancam system match
lancam b family operational characteristics 8 rev. 2 operational characteristics note: throughout the following, ?aaah? represents a three-digit hexadecimal number ?aaa,? while ?bbb? represents a two-digit binary number ?bb.? all memory locations are written to or read from in 16-bit segments. segment 0 corresponds to the lowest or der bits (bits 15?0) and segment 3 corresponds to the highest order bits (bits 63?48). control bus refer to figure 1 on page 1 for the following discussion. the inputs chip enable (/e), write enable (/w), command enable (/cm), and enable daisy chain (/ec) are the primary control mechanism for the lancam. the /ec input of the control bus enables the /mf match flag output when low and controls the daisy chain operation. instructions are the secondary control mechanism. logical combinations of the control bus inputs, coupled with the execution of select persistent source (sps), select persistent destination (spd), and temporary command override (tco) instructions allow the i/o operations to and from the dq15?0 lines to the internal resources, as shown in table 2. the comparand register is the default source and destination for data read and write cycles. this default state can be overridden independently by executing a select persistent source or select persistent destination instruction, selecting a different source or destination for data. subsequent data read or data write cycles access that source or destination until another sps or spd instruction is executed. the currently selected persistent source or destination can be read back through a tco ps or pd instruction. the sources and destinations available for persistent access are those resources on the 64-bit bus: comparand register, mask register 1, mask register 2, and the memory array. the default destination for command write cycles is the instruction decoder, while the default source for command read cycles is the status register. temporary command override (tco) instructions provide access to the control register, the page address register, the segment control register, the address register, the next free address register, and device select register. tco instructions are active only for one command read or write cycle after being loaded into the instruction decoder. the data and control interfaces to the lancam are synchronous. during a write cycle, the control and data inputs are registered by the falling edge of /e. when writing to the persistently selected data destination, the destination segment counter is clocked by the rising edge of /e. during a read cycle, the control inputs are registered by the falling edge of /e, and the data outputs are enabled while /e is low. when reading from the persistently selected data source, the source segment counter is clocked by the rising edge of /e. the register set the control, segment control, address, mask register 1, and the persistent source and destination registers are duplicated, with one set termed the foreground set and the other the background set. the active set is chosen by issuing select foreground registers or select background registers instructions. by default, the foreground set is active after a reset. having two alternate sets of registers that determine the device configuration allows for a rapid return to a foreground network filtering task from a background housekeeping task. writing a value to the control register or writing data to the last segment of the comparand or either mask register causes an automatic comparison to occur between the contents of the comparand register and the words in the cam segments of the memory marked valid, masked by mr1 or mr2 if selected in the control register. instruction decoder the instruction decoder is the write-only decode logic for instructions and is the default destination for command write cycles. if an instruction?s address field flag (bit 11) is set to a 1, it is a two-cycle instruction that is not executed immediately. for the next cycle only, the data from a command write cycle is loaded into the address register and the instruction then completes at that address. the address register then increments, decrements, or stays at the same value depending on the setting of control register bits ct3 and ct2. if the address field flag is not set, the memory access occurs at the address currently contained in the address register. control register (ct) the control register contains a number of switches that configure the lancam, as shown in control register bits on page 23. it is written or read using a tco ct instruction. if bit 15 of the value written during a tco ct is a 0, the device is reset (and all other bits are ignored). see table 3 on page 11 for the reset states. bit 15 always reads back as a 0. a write to the control register causes an automatic compare to occur (except in the case of a reset). either the foreground or background control register is active, depending on which register set has been selected, and only the active control register is written to or read from. if the match flag is disabled through bit 14 and bit 13, the internal match condition, /ma(int), used to determine a daisy-chained device?s response is forced high as shown in table 4 so that case 6 is not possible, effectively
operational characteristics lancam b family rev. 2 9 removing the device from the daisy chain. with the match flag disabled, /mf=/mi and operations directed to highest-priority match locations are ignored. normal operation of the device is with the /mf enabled. the match flag enable field has no effect on the /ma or /mm output pins or status register bits. these bits always reflect the true state of the device. if the full flag is disabled through bit 12 and bit 11, the device behaves as if it is full and ignores instructions to next free address. also, writes to the page address register are disabled. all other instructions operate normally. additionally, with the /ff disabled, /ff=/fi. normal operation of the device is with the /ff enabled. the full flag enable field has no effect on the /fl status register bit. this bit always reflects the true state of the device. the ieee translation control at bit 10 and bit 9 can be used to enable the translation hardware for writes to 64-bit resources in the device. when translation is enabled, the bits are reordered as shown in figure 6. figure 6: ieee 802.3/802.5 format mapping control register bits 8?6 control the cam/ram partitioning. the cam portion of each word may be sized from a full 64 bits down to 16 bits in 16-bit increments. the ram portion can be at either end of the 64-bit word. compare masks may be selected by bit 5 and bit 4. mask register 1, mask register 2, or neither may be selected to mask compare operations. the address register behavior is controlled by bit 3 and bit 2, and may be set to increment, decrement, or neither after a memory access. bit 1 and bit 0 set the operating mode: standard or enhanced as shown in table 4 on page 12. the device resets to the standard mode, and follows the operating responses of the original mu9c1480 in table 4. when operating in enhanced mode, it is not necessary to unlock the daisy chain with a nop instruction before command or data writes after a non-matching compare, as required in standard mode. segment control register (sc) the segment control register, as shown in segment control register bits on page 23, is accessed using a tco sc instruction. on read cycles, d15, d10, d5, and d2 always read back as 0s. either the foreground or background segment control register is active, depending on which register set is selected, and only the active segment control register is written to or read from. the segment control register contains dual independent incrementing counters with limits, one for data reads and one for data writes. these counters control which 16-bit segment of the 64-bit internal resource is accessed during a particular data cycle on the 16-bit data bus. the actual destination for data writes and source for data reads (called the persistent destination and source) are set independently with spd and sps instructions, respectively. each of the two counters consists of a start limit, an end limit, and the current count value that points to the segment to be accessed on the next data cycle. the current count value can be set to any segment, even if it is outside the range set by the start and end limits. the counters count up from the current count value to the end limit and then jump back to the start limit. if the current count is greater than the end limit, the current count value increments to three, rolls over to zero, continues incrementing until the end limit is reached, and then jumps back to the start limit. if a sequence of data writes or reads is interrupted, the segment control register can be reset to its initial start limit values by using an rsc instruction. after the lancam is reset, both source and destination counters are set to count from segment 0 to segment 3 with an initial value of 0. dq15 dq8 dq7 dq0 dq15 dq8 dq7 dq0
lancam b family operational characteristics 10 rev. 2 notes: 1. default command write cycle destination (does not require a tco instruction). 2. default command write cycle destination (no tco instruction required) if address field flag was set in bit 11 of the instruct ion loaded in the previous cycle. 3. loaded or read on the command write or read cycle immediately following a tco instruction. active for one command write or re ad cycle only. nfa register can not be loaded this way. 4. default command read cycle source (does not require a tco instruction). 5. default command read cycle source (does not require a tco instruction) if the previous cycle was a command read of status reg ister bits 15?0. if next cycle is not a command read cycle, any subsequent command read cycle accesses the status register bits 15?0. 6. default persistent source and destination on power-up and after reset. if other resources were sources or destinations, spd c r or sps cr restores the comparand register as the destination or source. 7. selected by executing a select persistent destination instruction. 8. selected by executing a select persistent source instruction. 9. access may require multiple 16-bit read or write cycles. the segment control register controls the selection of the desired 1 6-bit segment(s) by establishing the segment counters? start and end limits and count values. 10. device is deselected if device select register setting does not equal page address register setting, unless the device selec t register is set to ffffh, which allows only write access to the device. (writes to the device select register are always active.) device may also be deselected under locked daisy chain conditions as shown in table 4. 11. a command read cycle after a tco ps or tco pd reads back the instruction decoder bits that were last set to select a persist ent source or destination. the tco ps instruction also reads back the device id. table 2: input/output operations cycle type /e /cm /w i/o status sps spd tco operation notes cmd write l l l in in in in in in in 3 3 3 3 3 load instruction decoder load address register load control register load page address register load segment control register load device select register deselected 1 2,3 3 3 3 3 10 cmd read l l h out out out out out out out out out high-z 3 3 3 3 3 3 3 read next free address register read address register read status register bits 15?0 read status register bits 31?16 read control register read page address register read segment control register read device select register read current persistent source or destination deselected 3 3 4 5 3 3 3 3 3,11 10 data write l h l in in in in in in in 3 3 3 3 3 3 load comparand register load mask register 1 load mask register 2 write memory array at address write memory array at next free address write memory array at highest-priority match deselected 6,9 7,9 7,9 7,9 7,9 7,9 10 data read l h h out out out out out high-z 3 3 3 3 3 read comparand register read mask register 1 read mask register 2 read memory array at address read memory array at highest-priority match deselected 6, 9 8, 9 8, 9 8, 9 7, 8 10 h x x high-z deselected
operational characteristics lancam b family rev. 2 11 page address register (pa) the page address register is loaded using a tco pa instruction followed by a command write cycle of a user selected 16-bit value (not ffffh). the entry in the pa register gives a unique address to the different devices in a daisy chain. in a daisy chain, the pa value of each device is loaded using the sff instruction to advance to the next device, shown in the setting page address register values on page 16. a software reset (using the control register) does not affect the page address register. device select register (ds) the device select register selects a specific (target) device. the tco ds instruction sets the 16-bit ds register to the value of the following command write cycle. the ds register can be read. a device is selected when its ds is equal to its pa value. in a daisy chain, setting ds = ffffh selects all devices. however, in this case, the ability to read information out of the device is restricted as shown in table 4. a software reset (using the control register) does not affect the device select register. address register (ar) the address register points to the cam memory location to be operated upon when m@[ar] or m@aaah is part of the instruction. it can be loaded directly by using a tco ar instruction or indirectly by using an instruction requiring an absolute address, such as mov aaah,cr,v. after being loaded, the address register value is the next memory access referencing the address register. a reset sets the address register to zero. control register bits ct3 and ct2 set the address register to automatically increment or decrement (or not change) during sequences of command or data cycles. the address register changes after executing an instruction that includes m@[ar] or m@aaah, or after a data access to the end limit segment (as set in the segment control register) when the persistent source or destination is m@[ar] or m@aaah. either the foreground or background address register is active, depending on which register set is selected, and only the active address register is written to or read from. next free address register (nf) the lancam automatically stores the address of the first empty memory location in the next free address register, which is then used as a memory address pointer for m@nf operations. the next free address register, shown in next free address bits on page 24, can be read using a tco nf instruction. by taking /ec low during the tco nf instruction cycle, only the device with /fi low and /ff high outputs the contents of its next free address register, giving the next free address in a system of daisy-chained devices. the next free address may be read from a specific device in the chain by setting the device select register to the value of the desired device?s page address and leaving /ec high. the full flag daisy chain causes only the device whose /fi input is low and /ff output high to respond to an instruction using the next free address. after a reset, the next free address register is set to zero. table 3: device control state after reset cam status /reset condition validity bits at all memory locations match and full flag outputs ieee 802.3?802.5 input translation cam/ram partitioning comparison masking address register auto-increment or auto-decrement source and destination segment counters count ranges address register and next free address register page address and device select registers control register after reset (including ct15) persistent destination for command writes persistent source for command reads persistent source and destination for data reads and writes operating mode configuration register set skip = 0, empty = 1 (empty) enabled not translated 64 bits cam, 0 bits ram disabled disabled 00b to 11b; loaded with 00b contain all 0s contain all 0s (no change on software reset) contains 0008h instruction decoder status register comparand register standard foreground
lancam b family operational characteristics 12 rev. 2 notes: 1. exceptions are: a) a write to the device select register is always active in all devices; b) a write to the page address register is active in the device with /fi low and /ff high; and c) the set full flag (sff) instruction is active in the device with /fi low and /ff high. 2. if /mf is disabled in the control register, internal /ma is forced high preventing a case 6 response. 3. this is no for a mov instruction involving memory at next free address if /fi is high or the device is full. 4. this is no if the persistent destination is memory at next free address and /fi is high or the device is full. 5. for a command read following a tco nf instruction, this is yes if the device contains the first empty location in a daisy cha in (i.e., /fi low and /ff high) and no if it does not. 6. this is no for a mov or vbc instruction involving memory at highest-priority match. 7. this is no if the persistent destination is memory at highest-priority match. status register the 32-bit status register, shown in status register bits on page 24, is the default source for command read cycles. bit 31 (internal full flag) goes low if the particular device has no empty memory locations. bit 30 is the internal multiple match flag, which goes low if a multiple match was detected. bit 29 and bit 28 are the validity bits, which reflect the validity of the last memory location read. after a reset, the validity bits read 11 until a read or move from memory has occurred. the rest of the status register down to bit 1 contains the page address of the device and the address of the highest-priority match. after a reset or a no-match condition, the match address bits are all 1s. bit 0 is the internal match flag, which goes low if a match was found in this particular device. comparand register (cr) the 64-bit comparand register is the default destination for data writes and reads, using the segment control register to select which 16-bit segment of the comparand register is to be loaded or read out. the persistent source and destination for data writes and reads can be changed to the mask registers or memory by sps and spd instructions. during an automatic or forced compare, the comparand register is simultaneously compared against the cam portion of all memory locations with the correct validity condition. automatic compares always compare against valid memory locations, while forced compares, using cmp instructions, can compare against memory locations tagged with any specific validity condition. the comparand register may be shifted one bit at a time to the right or left by issuing a shift right or shift left instruction, with the right and left limits for the wrap-around determined by the cam/ram partitioning table 4: standard and enhanced mode device select response standard mode case internal /ec(int) internal /ma(int) external /mi device select register command write 1 data write command read data read 1 1 x x ds = ffffh yes 3 yes 4 no no 2 1 x x ds = pa yes 3 yes 4 yes yes 31 x xds ffffh and ds pa no no no no 40 x 0 x nono no 5 no 50 1 1 x nono no 5 no 6 2 001 x yes 3 yes 4 yes 5 yes enhanced mode case internal /ec(int) internal /ma(int) external /mi device select register command write 1 data write command read data read 1 1 x x ds = ffffh yes 3 yes 4 no no 2 1 x x ds = pa yes 3 yes 4 yes yes 31 x xds ffffh and ds pa no no no no 40 0 0 x yes 3,6 yes 3,7 no 5 no 50 1 x x yes 3,6 yes 3,7 no 5 no 6 2 001 x yes 3 yes 4 yes 5 yes
operational characteristics lancam b family rev. 2 13 set in the control register. during shift rights, bits shifted off the lsb of the cam partition reappear at the msb of the cam partition. likewise, bits shifted off the msb of the cam partition reappear at the lsb during shift lefts. mask registers (mr1, mr2) the mask registers can be used in two different ways: either to mask compares or to mask data writes and moves. either mask register can be selected in the control register to mask every compare, or selected by instructions to participate in data writes or moves to and from memory. if a bit in the selected mask register is set to a 0, the corresponding bit in the comparand register enters into a masked compare operation. if a mask bit is a 1, the corresponding bit in the comparand register does not enter into a masked compare operation. bits set to 0 in the mask register cause corresponding bits in the destination register or memory location to be updated when masking data writes or moves, while a bit set to 1 prevents that bit in the destination from being changed. either the foreground or background mr1 can be set active, but after a reset, the foreground mr1 is active by default. mr2 incorporates a sliding mask, where the data can be replicated one bit at a time to the right or left with no wrap-around by issuing a shift right or shift left instruction. the right and left limits are determined by the cam/ram partitioning set in the control register. for a shift right the upper limit bit is replicated to the next lower bit, while for a shift left the lower limit bit is replicated to the next higher bit. the memory array memory organization the memory array is organized into 64-bit words with each word having an additional two validity bits. by default, all words are configured to be 64 cam cells. however, bits 8?6 of the control register can divide each word into a cam field and a ram field. the ram field can be assigned to the least-significant or most-significant portion of each entry. the cam/ram partitioning is allowed on 16-bit boundaries, permitting selection of the configuration shown in control register bits on page 23, bits 8?6 (e.g., ?001? sets the 48 msbs to cam and the 16 lsbs to ram). memory array bits designated as ram can be used to store and retrieve data associated with the cam content at the same memory location. memory access there are two general ways to get data into and out of the memory array: directly or by moving the data by means of the comparand or mask registers. the first way, through direct reads or writes, is set up by issuing a set persistent destination (spd) or set persistent source (sps) command. the addresses for the direct access can be supplied directly; supplied from the address register, supplied from the next free address register, or supplied as the highest-priority match address. additionally, all the direct writes can be masked by either mask register. the second way is to move data by means of the comparand or mask registers. this is accomplished by issuing data move commands (mov). moves using the comparand register can also be masked by either of the mask registers. figure 7: read cycle /e dq15-0 /w /cm /ec data out
lancam b family operational characteristics 14 rev. 2 figure 8: write cycle figure 9: cycle-to-cycle timing example i/o cycles the lancam supports four basic i/o cycles: data read, data write, command read, and command write. the states of the /w and /cm control inputs determine the type of cycle. these signals are registered at the beginning of a cycle by the falling edge of /e. table 1 on page 3 shows how the /w and /cm signals select the cycle type. during read cycles, the dq15?0 outputs are enabled after /e goes low. during write cycles, the data or command to be written is captured from dq15?0 at the beginning of the cycle by the falling edge of /e. figure 10 on page 15 and figure 7 on page 13, show read and write cycles respectively. figure 8 on page 14, shows typical cycle-to-cycle timing with the match flag valid at the end of the comparand write. data writes and reads to the comparand, mask registers, or memory occur in one to four 16-bit cycles, depending on the settings in the segment control register. the compare operation automatically occurs during data writes to the comparand or mask registers when the destination segment counter reaches the end count set in the segment control register. if there was a match, the second cycle reads status or associated data, depending on the state of /cm. for cascaded devices, /ec needs to be low at the start of the cycle prior to any cycle that requires a locked daisy chain, such as a status register or associated data read after a match. if there is no match in standard mode, the output buffers stay high-z, and the daisy chain must be unlocked by taking /ec high during a nop or other non-functioning cycle, as indicated in table 4 on page 12. figure 9 on page 14 shows how the internal /ec timing holds the daisy chain locking effect over into the next cycle. in enhanced mode, this nop is not needed before data or command writes following a non-matching compare, as indicated by table 4 on page 12. a single-chip system does not require daisy-chained match flag operation, hence /ec could be tied high and the /ma pin or flag in the status register used instead of /mf, allowing access to the device regardless of the match condition. the minimum timings for the /e control signal are given in table 9 on page 27. note that at minimum timings the /e signal is non-symmetrical and that different cycle types have different timing requirements, as given in table 6 on page 22. dq15?0 /w /cm /e /ec associated data read cycle /ma and /mm flags updated data match flag valid dq15?0 /w /cm /ma, /mm /ec /mf /e comparand write cycle status read cycle data data
operational characteristics lancam b family rev. 2 15 compare operations during a compare operation, the data in the comparand register is compared to all locations in the memory array simultaneously. any mask register used during compares must be selected beforehand in the control register. there are two ways compares are initiated: automatic compare and forced compare. automatic compares perform a compare of the contents of the comparand register against memory locations that are tagged as ?valid,? and occur whenever the following happens:  the destination segment counter in the segment control register reaches its end limit during writes to the comparand or mask registers.  after a command write of a tco ct is executed (except for a software reset), so that a compare is executed with the new settings of the control register. forced compares are initiated by cmp instructions using one of the four validity conditions: v, r, s, and e. the forced compare against ?empty? locations automatically masks all 64 bits of data to find all locations with the validity bits set to ?empty,? while the other forced compares are only masked as selected in the control register. vertical cascading lancams can be vertically cascaded to increase system depth. through the use of flag daisy-chaining, multiple devices respond as an integrated system. the flag daisy chain allows all commands to be issued globally, with a response only in the device containing the highest-priority matching or next free location. when connected in a daisy chain, the last device?s full flag and match flag accurately report the condition for the whole string. a system in which lancams are vertically cascaded using daisy-chaining of the flags is shown in figure 4 on page 7. to operate the daisy chain, the device select registers are set to ffffh to enable all devices to execute command write and data write cycles. in normal operation, read cycles are enabled from the device with the highest-priority match by locking the daisy chain (see the locked daisy chain section). an individual device in the chain may be targeted for a read or write operation by temporarily setting the device select registers to the page address of the target device. setting the device select registers back to ffffh restores the operation of the entire daisy chain. match flag cascading the match flag daisy chain cascading has three purposes: first, to allow operations on highest-priority match addresses to be issued globally over the whole string; second, to provide a system wide match flag; third, to lock out all devices except the one with the highest-priority match for instructions such as status reads after a match. the match flag logic causes only the highest-priority device to operate on its highest-priority match location while devices with lower-priority matches ignore highest-priority match operations. the lock-out feature is enabled by the match flag cascading and the use of the /ec control signal, as shown in table 4. the ripple delay of the flags when connected in a daisy chain requires the extension of the /e high time until the logic in all devices has settled out. in a string of ?n? devices, the /e high time should be greater than if the last device?s match flag is required by external logic or a state machine before the start of the next cam cycle, one additional tmivmfv should be added to the /e high time along with the setup time and delays for the external logic. figure 10: /ec (int) timing diagram locked daisy chain in a locked daisy chain, the highest-priority device is the one with /mi high and /mf low. in standard mode, only this device responds to command and data reads and writes, until the daisy chain has been unlocked by taking /ec high. this allows reading the associated data field from only the highest-priority match location anywhere in a string of devices, or the match address from the status register of the device with the match. it also permits updating the entry stored at the highest-priority match location. in enhanced mode, devices are enabled to respond to some command and data writes, as noted in table 4 on page 12, but not command and data reads. table 4 (standard and enhanced modes) show when a device responds to reads or writes and when does not, based on the state of /ec(int), the internal match condition, and other control inputs. /ec is latched by the falling edge of /e. /ec(int) is registered from the latched /ec signal off the rising edge of /e, so it controls what happens in the next cycle, as shown in figure 10 on page tehmfv + (n-2) tmivmfv /e /ec /ec (int) /mf
lancam b family operational characteristics 16 rev. 2 15. when /ec is first taken low in a string of lancam devices (and assuming the device select registers are set to ffffh), all devices respond to that command write or data write. from then on the daisy chain remains locked in each subsequent cycle as long as /ec is held low on the falling edge of /e in the current cycle. when the daisy chain is locked in standard mode, only the highest-priority match device responds (see case 6 of table 4). if, for example, all of the cam memory locations were empty, there would be no match, and /mf would stay high. since none of the devices could then be the highest-priority match device, none respond to reads or writes until the daisy chain is unlocked by taking /ec high and asserting /e for a cycle. if there is a match between the data in the comparand register and one or more locations in memory, then only the highest-priority match device responds to any cycle, such as an associated data or status register read. if there is not a match, then a nop with /ec high needs to be inserted before issuing any new instructions, such as write to next free address instruction to learn the data. since next free operations are controlled by the /fi?/ff daisy chain, only the device with the first empty location responds. if an instruction is used to unlock the daisy chain, it works only on the highest-priority match device, if one exists. if none exists, the instruction has no effect except to unlock the daisy chain. to read the status registers of specific devices when there is no match requires the use of the tco ds command to set ds=pa of each device. single chip systems can tie /ec high and read the status register or the /ma and /mm pins to monitor match conditions, as the daisy chain lock-out feature is not needed in this configuration. this removes the need to insert a nop in the case of a no-match. when the control register is set to enhanced mode, you can continue to write data to the comparand register or issue a move to next free address instruction without first having to issue a nop with /ec high to unlock the daisy chain after a compare cycle with no match, as indicated in cases 4 and 5 of table 4 on page 12. in enhanced mode, data write cycles as well as command write cycles are enabled in all devices even when /ec is low. exceptions are data writes, moves, or vbc instructions involving hm, which occur only in the device with the highest match; and data writes or move instructions involving nf, which occur only in the device with /fi low and /ff high. enhanced mode speeds up system performance by eliminating the need to unlock the daisy chain before command or data write cycles. full flag cascading the full flag daisy chain cascading has the following three purposes:  allow instructions that address next free locations to operate globally  provide a system wide full flag  allow the loading of the page address registers during initialization using the sff instruction the full flag logic causes only the device containing the first empty location to respond to next free instructions such as mov nf,cr,v, which moves the contents of the comparand register to the first empty location in a string of devices and sets that location valid, making it available for the next automatic compare. with devices connected as in figure 4 on page 7, the /ff output of the last device in a string provides a full indication for the entire string. ieee 802.3/802.5 format mapping to support the symmetrical mapping between the address formats of ieee 802.3 and ieee 802.5, the lancam provides a bit translation facility. formally expressed, the nth input bit, d(n), maps to the xth output bit, q(x), through the following expressions: setting control register bit 10 and bit 9 selects whether to persistently translate, or persistently not to translate, the data written onto the 64-bit internal bus. the default condition after a reset command is not to translate the incoming data. figure 6 on page 9 shows the bit mapping between the two formats. initializing the lancam initialization of the lancam is required to configure the various registers on the device. since a control register reset establishes the operating conditions shown in table 3 on page 11, restoration of operating conditions better suited for the application may be required after a reset, whether using the control register reset, or the /reset pin. when the device powers up, the memory and registers are in an unknown state, so the /reset pin must be asserted to place the device in a known state. setting page address register values in a vertically cascaded system, the user must set the individual page address registers to unique values by using the page address initialization mechanism. each page address register must contain a unique value to prevent bus contention. this process allows individual device selection. the page address register initialization works as follows: writes to page address registers are only active for devices with /fi low and /ff high. at d(n) = q(7?n) for 0 < n < 7, d(n) = q(23?n) for 8 < n < 15
operational characteristics lancam b family rev. 2 17 initialization, all devices are empty, thus the top device in the string responds to a tco pa instruction, and loads its pa register. a set full flag (sff) instruction advances to the next device in the string and is active only for the device with /fi low and /ff high. the sff instruction changes the first device?s /ff to low, although the device really is empty, which allows the next device in the string to respond to the tco pa instruction and load its pa register. the initialization proceeds through the chain in a similar manner filling all the pa registers in turn. each device must have a unique page address value stored in its pa register, or contention results. after all the pa registers are filled, the entire string is reset through the control register, which does not change the values stored in the individual pa registers. after the reset, the device select registers usually are set to ffffh to enable operation in case 1 of table 4 on page 12. the control registers and the segment control registers are then set to their normal operating values for the application. vertically cascaded system initialization table 5 shows an example of code that initializes a daisy-chained string of lancam devices. the initialization example shows how to set the page address registers of each of the devices in the chain through the use of the set full flag instruction, and how the control registers and segment counters of all the lancam devices are set for a typical application. each page address register must contain a unique value (not ffffh) to prevent bus contention. for typical daisy chain operation, data is loaded into the comparand registers of all the devices in a string simultaneously by setting ds=ffffh. since reading is prohibited when ds=ffffh (except for the device with a match), for a diagnostic operation you need to select a specific device by setting ds=pa for the desired device to be able to read from it. refer to table 4 on page 12 for preconditions for reading and writing. initialization for a single lancam is similar. the device select register in this case is usually set to equal the page address register for normal operations. also, the dedicated /ma flag output can be used instead of /mf, allowing /ec to be tied high. notes: 1. toggling the /reset pin generates the same effect as this reset of the control register, but good programming practice dictat es a software reset for initialization to account for all possible prior conditions. 2. this instruction may be omitted for a single lancam application. 3. the last sff causes the /ff pin in the last chip in a daisy chain to go low. in a daisy chain, ds needs to be set equal to pa to read out a particular chip prior to a match condition. 4. a typical lancam control environment: enable match flag; enable full flag; 48 cam bits, 16 ram bits; disable comparison maski ng; and enable address increment. see table on page 23 for control register bit assignments. table 5: initialization routine example cycle type op-code on dq bus control bus comments notes /e /cm /w /ec command read command write command write command write command write command write command write command write command write command write command write command write command write command write command write tco ds ffffh tco ct 0000h tco pa nnnnh sff tco ct 0000h tco ct 8040h tco sc 3808h sps m@hm l l l l l l l l l l l l l l l l l l l l l l l l l l l l l l h l l l l l l l l l l l l l l h h h h h h h h h h h h h h h clear power-up anomalies target device select register to disable local device selection. disable device select feature. target control register for reset. causes reset. target page address register to set page for cascaded operation. page address value. set full flag; allows access to next device (repeat previous two cycles plus this one for each device in chain. target control register for reset of full flags, but not page address. causes reset. target control register for initial values. control register value. target segment count control register set both segment counters to write to segment 1, 2, and 3, and read from segment 0. set data reads from segment 0 of the highest-priority match 1 2 2 2,3 1 1 4 4 4
lancam b family instruction set descriptions 18 rev. 2 instruction set descriptions notes: instruction cycle lengths given in table 6 on page 22. if f=1, the instruction requires an absolute address to be supplied on the following cycle as a command write. the value supplied on the second cycle of the instruction updates the address register. aft er operations involving m@[ar] or m@aaah, the address register increments or decrements depending on the setting in the control register. instruction: select persistent source (sps) binary op-code: 0000 f000 0000 0sss f address field flag sss selected source this instruction selects a persistent source for data reads, until another sps instruction changes it or a reset occurs. the default source after reset for data read cycles is the comparand register. setting the persistent source to m@aaah loads the address register with ?aaah? and the first access to that persistent source is at aaah, after which the ar value increments or decrements as set in the control register. the sps m@[ar] instruction does the same except the current address register value is used. instruction: select persistent destination (spd) binary op-code: 0000 f001 mmdd dvvv f address field flag mm mask register select ddd selected destination vvv validity setting for memory location destinations this instruction selects a persistent destination for data writes, which remains until another spd instruction changes it or a reset occurs. the default destination for data write cycles is the comparand register after a reset. when the destination is the comparand register or the memory array, the data written may be masked by either mask register 1 or mask register 2, so that only destination bits corresponding to bits in the mask register set to 0 are modified. an automatic compare occurs after writing the last segment of the comparand or mask registers, but not after writing to memory. setting the persistent destination to m@aaah loads the address register with ?aaah,? and the first access to that persistent destination is at aaah, after which the ar value increments or decrements as set in the control register. the spd m@[ar] instruction does the same except the current address register value is used. instruction: temporary command override (tco) binary op-code: 0000 0010 00dd d000 ddd register selected as source or destination for only the next command read or write cycle the tco instruction selects a register as the source or destination for only the next command read or write cycle, so a value can be loaded or read out of the register. subsequent command read or write cycles revert to reading the status register and writing to the instruction decoder. all registers but the nf, ps, and pd can be written to, and all can be read from. the status register is only available through non-tco command read cycles. reading the ps register also outputs the device id on bits 15?4 as shown in persistent source register bits on page 24. instruction: data move (mov) binary op-code: 0000 f011 mmdd dsss or 0000 f011 mmdd dvss f address field flag mm mask register select ddd destination of data sss source of data v validity setting if destination is a memory location the mov instruction performs a 64-bit move of the data in the selected source to the selected destination. if the source or destination is aaah, the address register is set to ?aaah.? for mov instructions to or from aaah or [ar], the address register increments or decrements from that value after the move completes, as set in the control register. data transfers between the memory array and the comparand register may be masked by either mask register 1 or mask register 2, in which case, only those bits in the destination that correspond to bits in the selected mask register set to 0 are changed. a memory location used as a destination for a mov instruction may be set to valid or left unchanged. if the source and destination are the same register, no net change occurs (a nop).
instruction set descriptions lancam b family rev. 2 19 instruction: validity bit control (vbc) binary op-code: 0000 f100 00dd dvvv f address field flag ddd destination of data vvv validity setting for memory location the vbc instruction sets the validity bits at the selected memory locations to the selected state. this feature can be used to find all valid entries by using a repetitive sequence of cmp v through a mask of all 1s followed by a vbc hm, s. if the vbc target is aaah, the address register is set to ?aaah.? for vbc instructions to or from aaah or [ar], the address register increments or decrements from that value after the operation completes, as set in the control register. instruction: compare (cmp) binary op-code: 0000 0101 0000 0vvv vvv validity condition a cmp v, s, or r instruction forces a comparison of valid, skipped, or random entries against the comparand register through a mask register, if one is selected. during a cmp e instruction, the compare is only done on the validity bits and all data bits are automatically masked. instruction: special instructions binary op-code: 0000 0110 00dd drrr ddd target resource rrr operation these instructions are a special set for the lancam to accommodate the added features over the mu9c1480. two alternate sets of configuration registers can be selected by using the select foreground and select background registers instructions. these registers are the control, segment control, address, mask register 1, and the ps and pd registers. an rsc instruction resets the segment control register count values for both the destination and source counters to the original start limits. the shift instructions shift the designated register one bit right or left. the right and left limits for shifting are determined by the cam/ram partitioning set in the control register. the comparand register is a barrel-shifter, and for the example of a device set to 64 bits of cam executing a shift comparand right instruction, bit 0 is moved to bit 63, bit 1 is moved to bit 0, and bit 63 is moved to bit 62. for a shift comparand left instruction, bit 63 is moved to bit 0, bit 0 is moved to bit 1, and bit 62 is moved to bit 63. mr2 acts as a sliding mask, where for a shift right instruction bit 1 is moved to bit 0, while bit 0 ?falls off the end,? and bit 63 is replicated to bit 62. for a shift mask left instruction, bit 0 is replicated to bit 1, bit 62 is moved to bit 63, and bit 63 ?falls off the end.? with shorter width cam fields, the bit limits on the right or left move to match the width of cam field. instruction: set full flag (sff) binary op-code: 0000 0111 0000 0000 the sff instruction is a special instruction used to force the full flag low to permit setting the page address register in vertically cascaded systems. instruction: no operation (nop) binary op-code: 0000 0011 0000 0000 the nop (no-op) belongs to the mov instructions, where a register is moved to itself. no change occurs within the device. this instruction is useful in unlocking the daisy chain in standard mode.
lancam b family instruction set summary 20 rev. 2 instruction set summary mnemonic format: ins dst, src[msk], val ins: instruction mnemonic dst : destination of the data src: source of the data msk: mask register used val: validity condition set at the location written instruction: select persistent source operation mnemonic op-code comparand register sps cr 0000h mask register 1 sps mr1 0001h mask register 2 sps mr2 0002h memory array at addr. reg. sps m@[ar] 0004h memory array at address sps m@aaah 0804h mem. at highest-priority match sps m@hm 0005h instruction: select persistent destination operation mnemonic op-code comparand register spd cr 0100h masked by mr1 spd cr[mr1] 0140h masked by mr2 spd cr[mr2] 0180h mask register 1 spd mr 0108h mask register 2 spd mr2 0110h mem. at addr. reg. set valid spd m@[ar],v 0124h masked by mr1 spd m@[ar][mr1],v 0164h masked by mr2 spd m@[ar][mr2],v 01a4h mem. at addr. reg. set empty spd m@[ar],e 0125h masked by mr1 spd m@[ar][mr1],e 0165h masked by mr2 spd m@[ar][mr2],e 01a5h mem. at addr. reg. set skip spd m@[ar],s 0126h masked by mr1 spd m@[ar][mr1],s 0166h masked by mr2 spd m@[ar][mr2],s 01a6h mem. at addr.reg. set random spd m@[ar],r 0127h masked by mr1 spd m@[ar][mr1],r 0167h masked by mr2 spd m@[ar][mr2],r 01a7h memory at address set valid spd m@aaah,v 0924h masked by mr1 spd m@aaah[mr1],v 0964h masked by mr2 spd m@aaah[mr2],v 09a4h memory at address set empty spd m@aaah,e 0925h masked by mr1 spd m@aaah[mr1],e 0965h masked by mr2 spd m@aaah[mr2],e 09a5h memory at address set skip spd m@aaah,s 0926h masked by mr1 spd m@aaah[mr1],s 0966h masked by mr2 spd m@aaah[mr2],s 09a6h memory at address set random spd m@aaah,r 0927h masked by mr1 spd m@aaah[mr1],r 0967h masked by mr2 spd m@aaah[mr2],r 09a7h mem. at highest-prio. match, valid spd m@hm,v 012ch masked by mr1 spd m@hm[mr1],v 016ch masked by mr2 spd m@hm[mr2],v 01ach mem. at highest-prio. match, emp. spd m@hm,e 012dh masked by mr1 spd m@hm[mr1],e 016dh masked by mr2 spd m@hm[mr2],e 01adh mem. at highest-prio. match, skip spd m@hm,s 012eh masked by mr1 spd m@hm[mr1],s 016eh masked by mr2 spd m@hm[mr2],s 01aeh mem. at high.-prio. match, random spd m@hm,r 012fh masked by mr1 spd m@hm[mr1],r 016fh masked by mr2 spd m@hm[mr2],r 01afh mem. at next free addr., valid spd m@nf,v 0134h masked by mr1 spd m@nf[mr1],v 0174h masked by mr2 spd m@nf[mr2],v 01b4h mem. at next free addr., empty spd m@nf,e 0135h maskedbymr1 spd m@nf[mr1],e 0175h maskedbymr2 spd m@nf[mr2],e 01b5h mem. at next free addr., skip spd m@nf,s 0136h masked by mr1 spd m@nf[mr1],s 0176h masked by mr2 spd m@nf[mr2],s 01b6h mem. at next free addr., random spd m@nf,r 0137h masked by mr1 spd m@nf[mr1],r 0177h masked by mr2 spd m@nf[mr2],r 01b7h instruction: temporary command override operation mnemonic op-code control register tco ct 0200h page address register tco pa 0208h segment control register tco sc 0210h read next free address tco nf 0218h address register tco ar 0220h device select register tco ds 0228h read persistent source tco ps 0230h read persistent destination tco pd 0238h instruction: data move operation mnemonic op-code comparand register from: no operation nop 0300h mask register 1 mov cr,mr1 0301h mask register 2 mov cr,mr2 0302h memory at address reg. mov cr,[ar] 0304h masked by mr1 mov cr,[ar][mr1] 0344h masked by mr2 mov cr,[ar][mr2] 0384h memory at address mov cr,aaah 0b04h masked by mr1 mov cr,aaah[mr1] 0b44h masked by mr2 mov cr,aaah[mr2] 0b84h mem. at highest-prio. match mov cr,hm 0305h maskedbymr1 mov cr,hm[mr1] 0345h maskedbymr2 mov cr,hm[mr2] 0385h mask register 1 from: comparand register mov mr1,cr 0308h no operation nop 0309h mask register 2 mov mr1,mr2 030ah memory at address reg. mov mr1,[ar] 030ch memory at address mov mr1,aaah 0b0ch mem. at highest-prio. match mov mr1,hm 030dh instruction: select persistent destination (contin- operation mnemonic op-code
instruction set summary lancam b family rev. 2 21 mask register 2 from: comparand register mov mr2,cr 0310h mask register 1 mov mr2,mr1 0311h no operation nop 0312h memory at address reg. mov mr2,[ar] 0314h memory at address mov mr2,aaah 0b14h mem. at highest-prio. match mov mr2,hm 0315h memory at address register, no change to validity bits, from: comparand register mov [ar],cr 0320h masked by mr1 mov [ar],cr[mr1] 0360h masked by mr2 mov [ar],cr[mr2] 03a0h mask register 1 mov [ar],mr1 0321h mask register 2 mov [ar],mr2 0322h memory at address register, location set valid, from: comparand register mov [ar],cr,v 0324h masked by mr1 mov [ar],cr[mr1],v 0364h masked by mr2 mov [ar],cr[mr2],v 03a4h mask register 1 mov [ar],mr1,v 0325h mask register 2 mov [ar],mr2,v 0326h memory at address, no change to validity bits, from: comparand register mov aaah0,cr 0b20h masked by mr1 mov aaah,cr[mr1] 0b60h masked by mr2 mov aaah,cr[mr2] 0ba0h mask register 1 mov aaah,mr1 0b21h mask register 2 mov aaah,mr2 0b22h memory at address, location set valid, from: comparand register mov aaah,cr,v 0b24h masked by mr1 mov aaah,cr[mr1],v 0b64h masked by mr2 mov aaah,cr[mr2],v 0ba4h mask register 1 mov aaah,mr1,v 0b25h mask register 2 mov aaah,mr2,v 0b26h memory at highest-priority match, no change to validity bits, from: comparand register mov hm,cr 0328h masked by mr1 mov hm,cr[mr1] 0368h masked by mr2 mov hm,cr[mr2] 03a8h mask register 1 mov hm,mr1 0329h mask register 2 mov hm,mr2 032ah memory at highest-priority match, location set valid, from: comparand register mov hm,cr,v 032ch masked by mr1 mov hm,cr[mr1],v 036ch masked by mr2 mov hm,cr[mr2],v 03ach mask register 1 mov hm,mr1,v 032dh mask register 2 mov hm,mr2,v 032eh memory at next free address, no change to validity bits, from: comparand register mov nf,cr 0330h masked by mr1 mov nf,cr[mr1] 0370h masked by mr2 mov nf,cr[mr2] 03b0h mask register 1 mov nf,mr1 0331h mask register 2 mov nf,mr2 0332h memory at next free address, location set valid, from: comparand register mov nf,cr,v 0334h masked by mr1 mov nf,cr[mr1],v 0374h masked by mr2 mov nf,cr[mr2],v 03b4h mask register 1 mov nf,mr1,v 0335h mask register 2 mov nf,mr2,v 0336h instruction: data move (continued) operation mnemonic op-code instruction: validity bit control operation mnemonic op-code set validity bits at address register set valid vbc [ar],v 0424h set empty vbc [ar],e 0425h set skip vbc [ar],s 0426h set random access vbc [ar],r 0427h set validity bits at address set valid vbc aaah,v 0c24h set empty vbc aaah,e 0c25h set skip vbc aaah,s 0c26h set random access vbc aaah,r 0c27h set validity bits at highest-priority match set valid vbc hm,v 042ch set empty vbc hm,e 042dh set skip vbc hm,s 042eh set random access vbc hm,r 042fh set validity bits at all matching locations set valid vbc alm,v 043ch set empty vbc alm,e 043dh set skip vbc alm,s 043eh set random access vbc alm,r 043fh instruction: compare operation mnemonic op-code compare valid locations cmp v 0504h compare empty locations cmp e 0505h compare skipped locations cmp s 0506h comp. random access locations cmp r 0507h instruction: special instructions operation mnemonic op-code shift comparand right sft cr, r 0600h shift comparand left sft cr, l 0601h shift mask register 2 right sft m2, r 0610h shift mask register 2 left sft m2, l 0611h select foreground registers sfr 0618h select background registers sbr 0619h reset seg. cont. reg. to initial val. rsc 061ah instruction: miscellaneous operation mnemonic op-code no operation nop 0300h set full flag sff 0700h
lancam b family instruction set summary 22 rev. 2 instruction cycle lengths note: the specific timing requirements for short, medium, and long cycles are given in the switching characteristics section under th e teleh parameter. for two cycle command writes (tco reg or any instruction with ?aaah? as the source or destination), the first cycle is short, and the second cycle is the length given. table 6: instruction cycle lengths cycle length cycle type command write command read data write data read short mov reg, reg (except l-70) tco reg (except ct) tco ct (non-reset, hma invalid) sps, spd, sfr sbr, rsc nop (except l-70) sft (a) comparand register (not last segment) mask register (not last segment) medium mov reg, mem mov reg, reg (l-70) tco ct (reset) vbc (nfa invalid) sft (l) nop (l-70) status register or 16-bit register sheets memory array (nfa invalid) comparand register mask register long mov mem, reg tco ct (non-reset, hma valid) cmp sff vbc (nfa valid) memory array (nfa valid) comparand register (last segment) mask register (last segment) memory array
register bit assignments lancam b family rev. 2 23 register bit assignments note: d15 reads back as 0. note: d15, d10, d5, and d2 are read back as 0s. control register bits device bit(s) name description all 15 rst 0 = reset 14:13 match flag 00 = enable 01 = disable 10 = reserved 11 = no change 12:11 full flag 00 = enable 01 = disable 10 = reserved 11 = no change 10:9 translation 00 = input not translated 01 = input translated 10 = reserved 11 = no change 8:6 cam/ram part 000 = 64 cam/0 ram 001 = 48 cam/16 ram 010 = 32 cam/32 ram 011 = 16 cam/48 ram 100 = 48 ram/16 cam 101 = 32 ram/32 cam 110 = 16 ram/48 cam 111 = no change 5:4 comp. mask 00 = none 01 = mr1 10 = mr2 11 = no change 3:2 ar inc/dec 00 = increment 01 = decrement 10 = disable 11 = no change 1:0 mode 00 = standard 01 = enhanced 10 = reserved 11 = no change segment control register bits device bit(s) name description all 15 sdl 0 = set destination segment limits 1 = no change 14:13 dcsl 00?11 = destination count start limit 12:11 dcel 00?11 = destination count end limit 10 ssl 0 = set source segment limits 1 = no change 9:8 scsl 00?11 = source count start limit 7:6 scel 00?11 = source count end limit 5 ldc 0 = load destination segment count 1 = no change 4:3 dscv 00?11 = destination seg. count value 2 lsc 0 = load source segment count 1 = no change 1:0 sscv 00?11 = source segment count value
lancam b family register bit assignments 24 rev. 2 note: the next free address register is read only, and is accessed by performing a command read cycle immediately following a tco nf instruction. note: the status register is read only, and is accessed by performing command read cycles. on the first cycle, bits 15?0 are output, and if a second command read cycle is issued immediately after the first command read cycle, bits 31?16 are output. note: the persistent source register is read only, and is accessed by performing a command read cycle immediately following a tco ps instruction. next free address bits device bit(s) name description 1480b 15:10 pa5?0 page address 9:0 nf9-0 next free address 4480b 15:12 pa3?0 page address 11:0 nf11-0 next free address 8480b 15:3 pa2?0 page address 12:0 nf7-0 next free address status register bits device bit(s) name description all 31 /fl 0 = internal cam full 30 /mm 0 = internal multiple match 29:28 vb1-0 00 = valid 01 = empty 10 = skip 11 = ram 1480b 27 0 reserved 26:16 pa15?5 page address (second read) 15:11 pa4?0 page address (first read) 10:1 am9?0 match address 4480b 27:16 pa14?3 page address (second read) 15:13 pa2?0 page address (first read) 12:1 am11?0 match address 8480b 27:16 pa3?2 page address (second read) 15:14 pa1?0 page address (first read) 13:1 am12?0 match address all 0 /ma match flag persistent source register bits device bit(s) name description 1480b 15:4 devid device id = 141h 4480b 15:4 devid device id = 440h 8480b 15:4 devid device id = 840h all 3:0 ps persistent source setting
electrical lancam b family rev. 2 25 electrical operating conditions voltages referenced to gnd at the device pin. notes: 1. 1.0 volts for a duration of 10 ns measured at the 50% amplitude points for input-only lines (see figure 12 on page 26). 2. common i/o lines are clamped, so that signal transients can not fall below -0.5 volts. average power supply current (ma) dc electrical characteristics capacitance absolute maximum ratings supply voltage -0.5 to 4.6 volts stresses exceeding those listed under absolute maximum ratings may induce failure. exposure to absolute maximum ratings for extended periods may reduce reliability. functionality at or above these conditions is not implied. all voltages referenced to gnd. voltage on all other pins -0.5 to vcc +0.5 volts (-2 volts for 10 ns, measured at the 50% point) temperature under bias -55 c to 125 c storage temperature -55 c to 125 c dc output current 20 ma (per output, one at a time, one second duration) symbol parameter min. typical max. units notes v cc operating supply voltage 3.0 3.3 3.6 volts v ih input voltage logic 1 2.0 v cc + 0.5 volts v il input voltage logic 0 -0.5 0.8 volts 1, 2 t a ambient operating temperature commercial 0 70 c still air industrial -40 85 c -50 -70 -90 device typ. max. typ. max. typ. max. 1480b 50 80 35 60 30 50 4480b 150 240 110 160 85 140 8480b 230 370 160 260 120 200 symbol parameter min. typical max. units notes i cc(sb) stand-by power supply current 2ma /e = high v oh output voltage logic 1 2.4 volts i oh = -2.0 ma v ol output voltage logic 0 0.4 volts i ol = 4.0 ma i iz input leakage current others -2 +2 av ss v in v cc /reset 6 9 15 kohms v in = 0 v test1, test2 6 10 13 kohms v in = v cc ;10 i oz output leakage current -10 10 av ss v out v cc dq n = high impedance symbol parameter max. units notes c in input capacitance 6 pf f = 1 mhz, v in = 0v c out output capacitance 7 pf f = 1 mhz, v out = 0v
lancam b family switching 26 rev. 2 ac test conditions switching switching test figures figure 11: ac test load figure 12: input signal waveform switching test figures component values table 7: ac test conditions input signal transitions 0.0 volts to 3.0 volts input signal rise time < 3 ns input signal fall time < 3 ns input timing reference level 1.5 volts output timing reference level 1.5 volts to device undertest r2 vcc r1 c1 input waveform 0v v 10ns 50 % amplitude point il (min ) table 8: switching test figures component values parameter all devices units vcc 3.3 volts r1 635 ohms r2 702 ohms c1 (includes jig) test load a 30 pf test load b 5 pf
switching lancam b family rev. 2 27 switching characteristics notes: 1. 1.0 volts for a duration of 10 ns measured at the 50% amplitude points for input-only lines (see figure 12 on page 26). 2. common i/o lines are clamped, so that signal transients can not fall below -0.5 volts. 3. over ambient operating temperature range and vcc(min.) to vcc(max.). 4. see table 6 on page 22. 5. control signals are /w, /cm, and /ec. 6. with load specified in figure 11 on page 26, test load a. 7. with load specified in figure 11 on page 26, test load b. 8. /e must be high during this period to ensure accurate default values in the configuration registers. 9. with output and i/o pins unloaded. 10. test1 and/or test2 may not be implemented on all versions of these products. table 9: switching characteristics cycle time -50 -70 -90 no. symbol parameter min. max. min. max. min. max notes 1t elel chip enable compare cycle time 50 70 90 2 t eleh chip enable low pulse width short cycle 15 15 25 4 medium cycle 30 35 50 4 long cycle 45 55 75 4 3t ehel chip enable high pulse width 5 15 15 4t cvel control input to chip enable low setup time 2 2 2 5 5t elcx control input from chip enable low hold time 10 10 10 5 6t elqx chip enable low to outputs active 3 3 3 6 7 t elqv chip enable low to outputs valid register read 30 30 50 4,6 memory read 40 52 75 4,6 8t ehqz chip enable high to outputs high-z 3 10 3 10 3 15 7 9t dvel data to chip enable low setup time 2 2 2 10 t eldx data from chip enable low hold time 10 10 10 11 t fivel full in valid to chip enable low setup time 0 0 0 12 t fivffv full in valid to full flag valid 5 5 7 13 t elffv chip enable low to full flag valid 35 50 75 14 t mivel match in valid to chip enable low setup time 0 0 0 15 t ehmfx chip enable high to /mf, /ma, /mm invalid 0 0 0 16 t mivmfv match in valid to /mf valid, /ma, /mm 4 5 7 17 t ehmfv chip enable high to /mf valid 16 16 25 18 t ehmxv chip enable high to /ma and /mm valid 18 18 25 19 t rlrh reset low pulse width 50 100 100 8
lancam b family timing diagrams 28 rev. 2 timing diagrams figure 13: read cycle figure 14: write cycle figure 15: compare cycle /e /w /cm /ec dq15 - 0 23 45 4 5 4 5 8 6 7 /e /w /cm dq15 - 0 23 4 5 45 10 9 /fi /ff 12 13 11 1 /e /w /cm 4 4 valid /ma, /mm 18 2 3 5 5 /ec 4 5 /mi 14 /mf 17 15 16
dual footprint connections lancam b family rev. 2 29 dual footprint connections the following illustration is a suggested dual footprint only, and is not intended as board-ready artwork. figure 16: dual footprint connections gnd gnd gnd gnd gnd gnd gnd gnd gnd vcc vcc vcc vcc vcc vcc gnd gnd gnd gnd gnd gnd gnd gnd gnd gnd gnd gnd vcc vcc vcc vcc vcc vcc gnd gnd gnd gnd /ma /ma /mi /mi /mf /mf /reset /reset /e /e / w / w dq4 dq4 dq5 dq5 gnd dq6 dq7 dq7 dq6 dq8 dq9 dq10 dq11 dq8 dq9 dq10 dq11 dq12 dq13 dq14 dq15 dq12 dq13 dq14 dq15 dq3 dq3 dq2 dq1 dq0 dq2 dq0 dq1 /ec /cm /mm /ff /fi /ec /cm /mm /ff /fi 1 1 44 64 11 12 16 17 22 32 23 33 33 48 49 34
lancam b family dual footprint connections 30 rev. 2 notes
packages lancam b family rev. 2 31 packages 44-pin tqfp figure 17: 44-pin tqfp package 64-pin tqfp figure 18: 64-pin tqfp package a2 a 1 hd d e he l l1 e b c pin 1 table 10: 44-pin tqfp dimensions dim. a1 dim. a2 dim. b dim. c dim. d dim. e dim. e dim. hd dim. he dim. l1 dim. l min. 0.05 1.35 0.22 0.08 10.00 10.00 0.80 12.00 12.00 1.00 0.45 nom. 1.40 0.30 0.60 max. 0.15 1.45 0.38 0.20 0.75 a2 a1 hd d e he l b e c l1 pin 1 table 11: 64-pin tqfp dimensions dim. a1 dim. a2 dim. b dim. c dim. d dim. e dim. e dim. hd dim. he dim. l1 dim. l min. 0.05 1.35 0.22 0.08 14.00 14.00 0.80 16.00 16.00 1.00 0.45 nom. 1.40 0.30 0.60 max. 0.15 1.45 0.38 0.20 0.75
lancam b family ordering information 32 rev. 2 ordering information note: for the 4480b-50tbc and 1480b-50tac check for availability before ordering. part number cycle time package temperature voltage mu9c8480b-50tbc mu9c8480b-70tbc mu9c8480b-90tbc 50 ns 70 ns 90 ns 64-pin tqfp 64-pin tqfp 64-pin tqfp 0?70 c 0?70 c 0?70 c 3.3 0.3 3.3 0.3 3.3 0.3 mu9c8480b-70tbi mu9c8480b-90tbi 70 ns 90 ns 64-pin tqfp 64-pin tqfp -40?85 c -40?85 c 3.3 0.3 3.3 0.3 mu9c4480b-50tbc mu9c4480b-70tbc mu9c4480b-90tbc 50 ns 70 ns 90 ns 64-pin tqfp 64-pin tqfp 64-pin tqfp 0?70 c 0?70 c 0?70 c 3.3 0.3 3.3 0.3 3.3 0.3 mu9c4480b-70tbi mu9c4480b-90tbi 70 ns 90 ns 64-pin tqfp 64-pin tqfp -40?85 c -40?85 c 3.3 0.3 3.3 0.3 mu9c1480b-50tac mu9c1480b-70tac mu9c1480b-90tac 50 ns 70 ns 90 ns 44-pin tqfp 44-pin tqfp 44-pin tqfp 0?70 c 0?70 c 0?70 c 3.3 0.3 3.3 0.3 3.3 0.3 MU9C1480B-70TAI mu9c1480b-90tai 70 ns 90 ns 44-pin tqfp 44-pin tqfp -40?85 c -40?85 c 3.3 0.3 3.3 0.3 music semiconductors? agent or distributor: music semiconductors reserves the right to make changes to its products and specifications at any time in order to improve on performance, manufacturability or reliability. information furnished by music is believed to be accura te, but no responsibility is assumed by music semiconductors for the use of said information, no r for any infringements of patents or of other third-party rights which may result from said use. no license is granted by implication or otherwise under any patent or pa tent rights of any music company. ? copyright 2000 and 2002, music semiconductors north american sales m u s i c s e m i c o n d u c t o rs 495 union ave.
, s u ite 1 b middlesex, nj 08846 usa t e l : 732 469-1886
f a x: 732 469-2397 usa only: 800 933-1550 tech support 888 226-6874 product info asian headquarters music semiconductors 11 0 e x c e l le nc e a ve . , s e p z 1 carmelray industrial park c a n l u b a n g, l a g u na p h i l ip p i n e s 40 28 t e l: + 63 49 5 4 9 - 1 4 80 fax: +63 49 549-1024 sales tel/fax: +632 723-6215 european headquarters music semiconductors p. o . b o x 1 8 4 6470 ed eygelshoven the netherlands tel: +31 43 455-2675 fax: +31 43 455-1573 w o r l dw i de h e a d qu a r t e r s music semiconductors 5 850 t . g . l ee b l vd , s u ite 34 5 o r la n do , f l 32 8 22 usa t e l : 407 850-1035
f a x: 407 850-1063 h ttp://www.musicsemi.com email: info@musicsemi.com


▲Up To Search▲   

 
Price & Availability of MU9C1480B-70TAI

All Rights Reserved © IC-ON-LINE 2003 - 2022  

[Add Bookmark] [Contact Us] [Link exchange] [Privacy policy]
Mirror Sites :  [www.datasheet.hk]   [www.maxim4u.com]  [www.ic-on-line.cn] [www.ic-on-line.com] [www.ic-on-line.net] [www.alldatasheet.com.cn] [www.gdcy.com]  [www.gdcy.net]


 . . . . .
  We use cookies to deliver the best possible web experience and assist with our advertising efforts. By continuing to use this site, you consent to the use of cookies. For more information on cookies, please take a look at our Privacy Policy. X